/**
 * Licensed to Apereo under one or more contributor license agreements. See the NOTICE file
 * distributed with this work for additional information regarding copyright ownership. Apereo
 * licenses this file to you under the Apache License, Version 2.0 (the "License"); you may not use
 * this file except in compliance with the License. You may obtain a copy of the License at the
 * following location:
 *
 * <p>http://www.apache.org/licenses/LICENSE-2.0
 *
 * <p>Unless required by applicable law or agreed to in writing, software distributed under the
 * License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
 * express or implied. See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.apereo.portal.events.aggr;

import java.io.Serializable;
import org.apereo.portal.events.aggr.groups.AggregatedGroupMapping;
import org.joda.time.DateTime;

/** Base of all aggregations which includes time, date, interval, group, and duration */
public interface BaseAggregation<
                K extends BaseAggregationKey, D extends BaseGroupedAggregationDiscriminator>
        extends Serializable {
    /**
     * @return The {@link DateTime} the aggregation is for, short cut for getting the same info from
     *     {@link #getDateDimension()} and {@link #getTimeDimension()}
     */
    DateTime getDateTime();

    /** @return The day the aggregation is for */
    DateDimension getDateDimension();

    /** @return The time of day the aggregation is for */
    TimeDimension getTimeDimension();

    /** @return The interval the aggregation is for */
    AggregationInterval getInterval();

    /** @return The group this aggregation is for, null if it is for all users */
    AggregatedGroupMapping getAggregatedGroup();

    /** @return Duration in minutes of the aggregated time span */
    int getDuration();

    /** @return The key for this aggregation */
    K getAggregationKey();

    /**
     * Return a discriminator used for organizing aggregation data into separate columns for
     * reporting purposes
     *
     * @return aggregation discriminator
     */
    D getAggregationDiscriminator();
}
